﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using acessaDB;
using Frame;
using System.Data;
using System.Configuration;
using FirebirdSql.Data.FirebirdClient;
using Estrutura;


namespace Banco
{

    public class BD_Estado
    {
        #region variaveis_globais

        acessaDB.conectaDBFireBird fireBird = new conectaDBFireBird();
        string conectionString = System.Configuration.ConfigurationManager.AppSettings["FireBirdConnectionLocal"];
        string usuario = string.Empty;

        #endregion

        #region construtor

        public BD_Estado()
        {
            if (System.Configuration.ConfigurationManager.AppSettings["ambiente"] == "PROD")
                conectionString = System.Configuration.ConfigurationManager.AppSettings["FireBirdConnectionProd"];
        }
        public BD_Estado(string usu_Login)
        {
            if (System.Configuration.ConfigurationManager.AppSettings["ambiente"] == "PROD")
                conectionString = System.Configuration.ConfigurationManager.AppSettings["FireBirdConnectionProd"];
            usuario = usu_Login;
        }

        #endregion

        #region metodos

        public DataSet _retorna_Estado(
                                                string ESTADO_ID,
                                                string PAIS_ID,
                                                string EST_SIGLA,
                                                string EST_NOME,
                                                string USU_INSERT,
                                                string DATA_INSERT,
                                                string USU_UPDATE,
                                                string DATA_UPDATE
                                                )
        {

            if (string.IsNullOrEmpty(ESTADO_ID)) ESTADO_ID = "'0'";
            if (string.IsNullOrEmpty(PAIS_ID)) PAIS_ID = "'0'";
            if (string.IsNullOrEmpty(EST_SIGLA)) EST_SIGLA = "''";
            if (string.IsNullOrEmpty(EST_NOME)) EST_NOME = "''";
            if (string.IsNullOrEmpty(USU_INSERT)) USU_INSERT = "'0'";
            if (string.IsNullOrEmpty(DATA_INSERT)) DATA_INSERT = "''";
            if (string.IsNullOrEmpty(USU_UPDATE)) USU_UPDATE = "'0'";
            if (string.IsNullOrEmpty(DATA_UPDATE)) DATA_UPDATE = "''";

            string sql = "SELECT " +
                                  "ESTADO.ESTADO_ID, " +
                                  "ESTADO.PAIS_ID, " +
                                  "ESTADO.EST_SIGLA, " +
                                  "ESTADO.EST_NOME, " +
                                  "ESTADO.USU_INSERT, " +
                                  "ESTADO.DATA_INSERT, " +
                                  "ESTADO.USU_UPDATE, " +
                                  "ESTADO.DATA_UPDATE " +
                            "FROM ESTADO " +
                            "LEFT JOIN PAIS ON PAIS.PAIS_ID = ESTADO.PAIS_ID " +
                            /*"LEFT JOIN USUARIO ON USUARIO.USUARIO_ID = ESTADO.USUARIO_ID " +
                            "LEFT JOIN USUARIO ON USUARIO.USUARIO_ID = ESTADO.USUARIO_ID " +*/
                            "WHERE " +
                            "      (ESTADO.ESTADO_ID                       = " + ESTADO_ID + "  OR " + ESTADO_ID + " = '0') AND " +
                            "      (ESTADO.PAIS_ID                         = " + PAIS_ID + "  OR " + PAIS_ID + " = '0') AND " +
                            "      (ESTADO.EST_SIGLA                       = " + EST_SIGLA + "  OR " + EST_SIGLA + " = '') AND " +
                            "      (ESTADO.EST_NOME                        = " + EST_NOME + "  OR " + EST_NOME + " = '') AND " +
                            "      (ESTADO.USU_INSERT                      = " + USU_INSERT + "  OR " + USU_INSERT + " = '0') AND " +
                            "      (ESTADO.DATA_INSERT                     = " + DATA_INSERT + "  OR " + DATA_INSERT + " = '') AND " +
                            "      (ESTADO.USU_UPDATE                      = " + USU_UPDATE + "  OR " + USU_UPDATE + " = '0') AND " +
                            "      (ESTADO.DATA_UPDATE                     = " + DATA_UPDATE + "  OR " + DATA_UPDATE + " = '') ";

            DataSet dsRetorno = fireBird.retornaDataSet(sql, conectionString);
            return dsRetorno;

        }


        public List<ES_Estado> _obter_Estado(
                                                string ESTADO_ID,
                                                string PAIS_ID,
                                                string EST_SIGLA,
                                                string EST_NOME,
                                                string USU_INSERT,
                                                string DATA_INSERT,
                                                string USU_UPDATE,
                                                string DATA_UPDATE
                                                )
        {

            if (string.IsNullOrEmpty(ESTADO_ID)) ESTADO_ID = "0";
            if (string.IsNullOrEmpty(PAIS_ID)) PAIS_ID = "0";
            if (string.IsNullOrEmpty(EST_SIGLA)) EST_SIGLA = "''"; else EST_SIGLA = Util.retonarAspas(EST_SIGLA + " % ");
            if (string.IsNullOrEmpty(EST_NOME)) EST_NOME = "''"; else EST_NOME = Util.retonarAspas(EST_NOME + " % ");
            if (string.IsNullOrEmpty(USU_INSERT)) USU_INSERT = "'0'";
            if (string.IsNullOrEmpty(DATA_INSERT)) DATA_INSERT = "''"; else DATA_INSERT = Util.retonarAspas(DATA_INSERT + " % ");
            if (string.IsNullOrEmpty(USU_UPDATE)) USU_UPDATE = "'0'";
            if (string.IsNullOrEmpty(DATA_UPDATE)) DATA_UPDATE = "''"; else DATA_UPDATE = Util.retonarAspas(DATA_UPDATE + " % ");

            string sql = "SELECT " +
                                  "ESTADO.ESTADO_ID, " +
                                  "ESTADO.PAIS_ID, " +
                                  "ESTADO.EST_SIGLA, " +
                                  "ESTADO.EST_NOME, " +
                                  "ESTADO.USU_INSERT, " +
                                  "ESTADO.DATA_INSERT, " +
                                  "ESTADO.USU_UPDATE, " +
                                  "ESTADO.DATA_UPDATE " +
                            "FROM ESTADO " +
                            "LEFT JOIN PAIS ON PAIS.PAIS_ID = ESTADO.PAIS_ID " +
                            /*"LEFT JOIN USUARIO ON USUARIO.USUARIO_ID = ESTADO.USUARIO_ID " +
                            "LEFT JOIN USUARIO ON USUARIO.USUARIO_ID = ESTADO.USUARIO_ID " +*/
                            "WHERE " +
                            "      (ESTADO.ESTADO_ID                       = " + ESTADO_ID + "  OR " + ESTADO_ID + " = 0) AND " +
                            "      (ESTADO.PAIS_ID                         = " + PAIS_ID + "  OR " + PAIS_ID + " = 0) AND " +
                            "      (ESTADO.EST_SIGLA                       = " + EST_SIGLA + "  OR " + EST_SIGLA + " = '') AND " +
                            "      (ESTADO.EST_NOME                        = " + EST_NOME + "  OR " + EST_NOME + " = '')  " +
                            /*"      (ESTADO.USU_INSERT                      = " + USU_INSERT + "  OR " + USU_INSERT + " = '0') AND " +
                            "      (ESTADO.DATA_INSERT                     = " + DATA_INSERT + "  OR " + DATA_INSERT + " = '') AND " +
                            "      (ESTADO.USU_UPDATE                      = " + USU_UPDATE + "  OR " + USU_UPDATE + " = '0') AND " +
                            "      (ESTADO.DATA_UPDATE                     = " + DATA_UPDATE + "  OR " + DATA_UPDATE + " = '') "+*/
                            "ORDER BY ESTADO.EST_NOME";

            List<ES_Estado> lista = new List<ES_Estado>();
            FbConnection fbConexao = new FbConnection(conectionString);
            FbDataReader dr = fireBird.retornaDataReader(sql, conectionString, fbConexao);
            try
            {
                while (dr.Read())
                {
                    ES_Estado item = new ES_Estado();
                    item.ESTADO_ID = dr["ESTADO_ID"].ToString();
                    item.PAIS_ID = dr["PAIS_ID"].ToString();
                    item.EST_SIGLA = dr["EST_SIGLA"].ToString();
                    item.EST_NOME = dr["EST_NOME"].ToString();
                    item.USU_INSERT = dr["USU_INSERT"].ToString();
                    item.DATA_INSERT = dr["DATA_INSERT"].ToString();
                    item.USU_UPDATE = dr["USU_UPDATE"].ToString();
                    item.DATA_UPDATE = dr["DATA_UPDATE"].ToString();
                    lista.Add(item);

                }
                return lista;
            }
            finally
            {
                fireBird.fecharConexao(fbConexao);
            }
        }


        public ES_Estado _obter_Estado_by_id(
                                                string ESTADO_ID
                                                )
        {

            if (string.IsNullOrEmpty(ESTADO_ID)) ESTADO_ID = "'0'";

            string sql = "SELECT " +
                                  "ESTADO.ESTADO_ID, " +
                                  "ESTADO.PAIS_ID, " +
                                  "ESTADO.EST_SIGLA, " +
                                  "ESTADO.EST_NOME, " +
                                  "ESTADO.USU_INSERT, " +
                                  "ESTADO.DATA_INSERT, " +
                                  "ESTADO.USU_UPDATE, " +
                                  "ESTADO.DATA_UPDATE " +
                            "FROM ESTADO " +
                            "LEFT JOIN PAIS ON PAIS.PAIS_ID = ESTADO.PAIS_ID " +
                            /*"LEFT JOIN USUARIO ON USUARIO.USUARIO_ID = ESTADO.USUARIO_ID " +
                            "LEFT JOIN USUARIO ON USUARIO.USUARIO_ID = ESTADO.USUARIO_ID " +*/
                            "WHERE " +
                            "      (ESTADO.ESTADO_ID = " + ESTADO_ID + "  OR " + ESTADO_ID + " = '0') ";

            ES_Estado item = new ES_Estado();
            FbConnection fbConexao = new FbConnection(conectionString);
            FbDataReader dr = fireBird.retornaDataReader(sql, conectionString, fbConexao);
            try
            {
                while (dr.Read())
                {
                    item.ESTADO_ID = dr["ESTADO_ID"].ToString();
                    item.PAIS_ID = dr["PAIS_ID"].ToString();
                    item.EST_SIGLA = dr["EST_SIGLA"].ToString();
                    item.EST_NOME = dr["EST_NOME"].ToString();
                    item.USU_INSERT = dr["USU_INSERT"].ToString();
                    item.DATA_INSERT = dr["DATA_INSERT"].ToString();
                    item.USU_UPDATE = dr["USU_UPDATE"].ToString();
                    item.DATA_UPDATE = dr["DATA_UPDATE"].ToString();

                }
                return item;
            }
            finally
            {
                fireBird.fecharConexao(fbConexao);
            }
        }


        public void _inserir_Estado(
                                                string ESTADO_ID,
                                                string PAIS_ID,
                                                string EST_SIGLA,
                                                string EST_NOME,
                                                string USU_INSERT,
                                                string DATA_INSERT,
                                                string USU_UPDATE,
                                                string DATA_UPDATE
                                                )
        {

            string sql = " INSERT INTO ESTADO " +
                         "      ( " +
                         "          PAIS_ID                        , " +
                         "          EST_SIGLA                      , " +
                         "          EST_NOME                       , " +
                         "          USU_INSERT                     , " +
                         "          DATA_INSERT                    , " +
                         "          USU_UPDATE                     , " +
                         "          DATA_UPDATE                      " +
                 "      )" +
                 "  VALUES " +
                 "      ( " +
                              Util.retonarAspas(PAIS_ID, true) + ", " +
                              Util.retonarAspas(EST_SIGLA, true) + ", " +
                              Util.retonarAspas(EST_NOME, true) + ", " +
                              Util.retonarAspas(USU_INSERT, true) + ", " +
                              Util.retonarAspas(DATA_INSERT, true) + ", " +
                              Util.retonarAspas(USU_UPDATE, true) + ", " +
                              Util.retonarAspas(DATA_UPDATE, true) +
                 "      )";
            try
            {
                fireBird._ExecutarComandoRetornandoID(sql, conectionString, false, usuario);
            }
            catch
            { }
        }



        public void _atualizar_Estado(
                                                string ESTADO_ID,
                                                string PAIS_ID,
                                                string EST_SIGLA,
                                                string EST_NOME,
                                                string USU_INSERT,
                                                string DATA_INSERT,
                                                string USU_UPDATE,
                                                string DATA_UPDATE
                                                )
        {

            string sql = " UPDATE ESTADO SET " +
                         "      PAIS_ID                         = " + Util.retonarAspas(PAIS_ID, true) + ", " +
                         "      EST_SIGLA                       = " + Util.retonarAspas(EST_SIGLA, true) + ", " +
                         "      EST_NOME                        = " + Util.retonarAspas(EST_NOME, true) + ", " +
                         "      USU_INSERT                      = " + Util.retonarAspas(USU_INSERT, true) + ", " +
                         "      DATA_INSERT                     = " + Util.retonarAspas(DATA_INSERT, true) + ", " +
                         "      USU_UPDATE                      = " + Util.retonarAspas(USU_UPDATE, true) + ", " +
                         "      DATA_UPDATE                     = " + Util.retonarAspas(DATA_UPDATE, true) +
                         " WHERE ESTADO_ID =  " + ESTADO_ID;
            try
            {
                fireBird._ExecutarComandoRetornandoID(sql, conectionString, false, usuario);
            }
            catch
            { }
        }



        public void _excluir_Estado(string ESTADO_ID)
        {
            string sql = "DELETE FROM ESTADO WHERE ESTADO_ID = " + ESTADO_ID;
            try
            {
                fireBird._ExecutarComandoRetornandoID(sql, conectionString, false, usuario);
            }
            catch
            { }
        }



        #endregion
    }
}
